<template>
  <j-modal
    :title="title"
    :width="width"
    :visible="visible"
    :confirmLoading="confirmLoading"
    :keyboard="false"
    :forceRender="true"
    v-bind:prefixNo="prefixNo"
    switchHelp
    switchFullscreen
    @cancel="handleCancel"
    :id="prefixNo"
    style="top:20px;height: 95%;">
    <template slot="footer">
      <a-button @click="customHandleCancel">取消</a-button>
<!--      <a-button v-if="checkFlag && isCanCheck" :loading="confirmLoading" @click="handleOkAndCheck">保存并审核</a-button>-->
      <a-button type="primary" :loading="confirmLoading" @click="handleOkSale(0)">保存</a-button>
      <a-button type="primary" :loading="confirmLoading" @click="handleOkSale(1)">保存并打印</a-button>
      <!--发起多级审核-->
      <a-button v-if="!checkFlag" @click="handleWorkflow()" type="primary">提交流程</a-button>
    </template>
    <a-spin :spinning="confirmLoading">
      <a-form :form="form">
        <a-row class="form-row" :gutter="24">
          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="客户" data-step="1" data-title="客户"
              data-intro="客户必须选择，如果发现需要选择的客户尚未录入，可以在下拉框中点击新增客户进行录入。
                          特别注意，客户如果录入之后在下拉框中不显示，请检查是否给当前用户分配对应的客户权限">
              <a-select style="width: 200px" placeholder="选择客户" v-decorator="[ 'organId', validatorRules.organId ]"
                :dropdownMatchSelectWidth="false" showSearch optionFilterProp="children" @change="handleOrganChange">
                <div slot="dropdownRender" slot-scope="menu">
                  <v-nodes :vnodes="menu" />
                  <a-divider style="margin: 4px 0;" />
                  <div v-if="isTenant" style="padding: 4px 8px; cursor: pointer;"
                       @mousedown="e => e.preventDefault()" @click="addCustomer"><a-icon type="plus" /> 新增客户</div>
                </div>
                <a-select-option v-for="(item,index) in cusList" :key="item.id" :value="item.id">
                  {{ item.supplier }}
                </a-select-option>
              </a-select>
            </a-form-item>
          </a-col>
          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="单据日期">
              <j-date style="width: 200px" v-decorator="['operTime', validatorRules.operTime]" :show-time="true"/>
            </a-form-item>
          </a-col>
          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="单据编号" data-step="2" data-title="单据编号"
              data-intro="单据编号自动生成、自动累加、开头是单据类型的首字母缩写，累加的规则是每次打开页面会自动占用一个新的编号">
              <a-input style="width: 200px" placeholder="请输入单据编号" v-decorator.trim="[ 'number' ]" :readOnly="isReadOnly"/>
            </a-form-item>
          </a-col>
          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="销售人员" data-step="3" data-title="销售人员"
              data-intro="销售人员的数据来自【经手人管理】菜单中的业务员">
              <j-select-multiple style="width: 200px" placeholder="请选择销售人员" v-model="personList.value" :options="personList.options"/>
            </a-form-item>
          </a-col>
        </a-row>
        <a-row class="form-row" :gutter="24">
          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="发货日期">
              <j-date @change='handleDateChange' style="width: 200px" :value="nowDate" :date-format="dateFormat" v-decorator="['sendDate', validatorRules.sendDate]" :show-time="false"/>
            </a-form-item>
          </a-col>
          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="销售区域">
              <a-cascader disabled
                          style="width: 200px" :field-names="{ label: 'name', value: 'id', children: 'children' }"
                          :options="cities" placeholder="请选择区域"
                          v-decorator="['city']"/>
            </a-form-item>
          </a-col>
          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="运输方式">
              <a-select @change='trafficChange' default-value="car" style="width: 200px" placeholder="请选择运输方式" v-decorator="['traffic', {initialValue: 'car'}]">
                <a-select-option key='car' value='car'>汽车</a-select-option>
                <a-select-option key='ship' value='ship'>轮船</a-select-option>
                <a-select-option key='train' value='train'>火车</a-select-option>
                <a-select-option key='self' value='self'>自提</a-select-option>
              </a-select>
            </a-form-item>
          </a-col>
          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="运费">
              <a-input style="width: 200px" v-decorator="['cost']" />
            </a-form-item>
          </a-col>
          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="承运人">
              <a-input style="width: 200px" v-decorator="['transfer']" />
            </a-form-item>
          </a-col>
          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="拆分单数">
              <a-input-number style="width: 200px" placeholder="请输入拆分单数" v-decorator="['splitNumber']" />
            </a-form-item>
          </a-col>
          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="每单发货间隔">
              <a-input-number style="width: 200px" placeholder="默认发货间隔7天" v-decorator="['dayCycle']" />
            </a-form-item>
          </a-col>
          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item  :labelCol="labelCol" :wrapperCol="wrapperCol" label="备注">
              <a-textarea :rows="1" placeholder="请输入备注" v-decorator="[ 'remark' ]" style="margin-top:8px;"/>
            </a-form-item>
          </a-col>
        </a-row>
        <j-editable-table id="billModal"
          :ref="refKeys[0]"
          :loading="materialTable.loading"
          :columns="materialTable.columns"
          :dataSource="materialTable.dataSource"
          :minWidth="minWidth"
          :maxHeight="300"
          :rowNumber="false"
          :rowSelection="true"
          :actionButton="true"
          :dragSort="true"
          :send-date='sendDate'
          @valueChange="onValueChange"
          @added="onAddedSale"
          @deleted="onDeleted">
          <template #buttonAfter>
<!--            <a-row :gutter="24" style="float:left;padding-bottom: 5px;" data-step="4" data-title="扫码录入" data-intro="此功能支持扫码枪扫描商品条码进行录入">
              <a-col v-if="scanStatus" :md="6" :sm="24">
                <a-button @click="scanEnter">扫码录入</a-button>
              </a-col>
              <a-col v-if="!scanStatus" :md="16" :sm="24" style="padding: 0 8px 0 12px">
                <a-input placeholder="请扫描商品条码并回车" v-model="scanBarCode" @pressEnter="scanPressEnter" ref="scanBarCode"/>
              </a-col>
              <a-col v-if="!scanStatus" :md="6" :sm="24" style="padding: 0px 18px 0 0">
                <a-button @click="stopScan">收起扫码</a-button>
              </a-col>
            </a-row>-->
            <a-row :gutter="24" style="float:left;padding-bottom: 5px;">
              <a-col :md="24" :sm="24">
                <a-button @click="isSplitting" style="margin-left: 8px" ><a-icon type="scissor" />{{splittingButton}}</a-button>
              </a-col>
            </a-row>
<!--            <a-row :gutter="24" style="float:left;padding-bottom: 6px;">
              <a-col :md="24" :sm="24">
                <a-button style="margin-left: 15px" @click="handleHistoryBillList"><a-icon type="history" />历史单据</a-button>
              </a-col>
            </a-row>-->
<!--            <a-row :gutter="24" style="float:left;padding-bottom: 5px;padding-left:20px;">
              <a-button icon="import" @click="onImport(prefixNo)">导入明细</a-button>
            </a-row>-->
          </template>
        </j-editable-table>
        <a-row class="form-row" :gutter="24">
<!--          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="优惠率" data-step="5" data-title="优惠率"
                         data-intro="针对单据明细中商品总金额进行优惠的比例">
              <a-input style="width:185px;" placeholder="请输入优惠率" v-decorator.trim="[ 'discount' ]" suffix="%" @change="onChangeDiscount"/>
            </a-form-item>
          </a-col>
          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="收款优惠" data-step="6" data-title="收款优惠"
                         data-intro="针对单据明细中商品总金额进行优惠的金额">
              <a-input placeholder="请输入付款优惠" v-decorator.trim="[ 'discountMoney' ]" @change="onChangeDiscountMoney"/>
            </a-form-item>
          </a-col>-->
          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="总金额" data-step="7" data-title="优惠后金额"
                         data-intro="针对单据明细中商品总金额进行优惠后的金额">
              <a-input placeholder="请输入优惠后金额" v-decorator.trim="[ 'discountLastMoney' ]" :readOnly="true"/>
            </a-form-item>
          </a-col>
          <a-col :lg="6" :md="12" :sm="24"></a-col>
        </a-row>
        <a-row class="form-row" :gutter="24">
          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="结算账户" data-step="8" data-title="结算账户"
                         data-intro="如果在下拉框中选择多账户，则可以通过多个结算账户进行结算">
              <a-select style="width:185px;" placeholder="选择结算账户" v-decorator="[ 'accountId', validatorRules.accountId ]"
                        :dropdownMatchSelectWidth="false" allowClear @select="selectAccount">
                <div slot="dropdownRender" slot-scope="menu">
                  <v-nodes :vnodes="menu" />
                  <a-divider style="margin: 4px 0;" />
                  <div v-if="isTenant" style="padding: 4px 8px; cursor: pointer;"
                       @mousedown="e => e.preventDefault()" @click="addAccount"><a-icon type="plus" /> 新增结算账户</div>
                </div>
                <a-select-option v-for="(item,index) in accountList" :key="index" :value="item.id">
                  {{ item.name }}
                </a-select-option>
              </a-select>
              <a-tooltip title="多账户明细">
                <a-button type="default" icon="folder" style="margin-left: 8px;" size="small" v-show="manyAccountBtnStatus" @click="handleManyAccount"/>
              </a-tooltip>
            </a-form-item>
          </a-col>
<!--          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="收取订金" data-step="9" data-title="收取订金"
                         data-intro="填写订金之后，在销售出库单会自动计算扣除订金">
              <a-input placeholder="请输入收取订金" v-decorator.trim="[ 'changeAmount', validatorRules.price ]" @change="onChangeChangeAmount"/>
            </a-form-item>
          </a-col>-->
          <a-col :lg="6" :md="12" :sm="24">
          </a-col>
          <a-col :lg="6" :md="12" :sm="24">
          </a-col>
        </a-row>
        <a-row class="form-row" :gutter="24">
          <a-col :lg="6" :md="12" :sm="24">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="附件" data-step="10" data-title="附件" data-intro="可以上传与单据相关的图片、文档，支持多个文件">
              <j-upload v-model="fileList" bizPath="bill"></j-upload>
            </a-form-item>
          </a-col>
        </a-row>
      </a-form>
    </a-spin>
    <many-account-modal ref="manyAccountModalForm" @ok="manyAccountModalFormOk"></many-account-modal>
    <import-item-modal ref="importItemModalForm" @ok="importItemModalFormOk"></import-item-modal>
    <customer-modal ref="customerModalForm" @ok="customerModalFormOk"></customer-modal>
    <account-modal ref="accountModalForm" @ok="accountModalFormOk"></account-modal>
    <history-bill-list ref="historyBillListModalForm"></history-bill-list>
    <workflow-iframe ref="modalWorkflow"></workflow-iframe>
    <sale-order-print ref='print' :model='record' :data-source='cols'></sale-order-print>
  </j-modal>
</template>
<script>
  import pick from 'lodash.pick'
  import ManyAccountModal from '../dialog/ManyAccountModal'
  import ImportItemModal from '../dialog/ImportItemModal'
  import CustomerModal from '../../system/modules/CustomerModal'
  import AccountModal from '../../system/modules/AccountModal'
  import HistoryBillList from '../dialog/HistoryBillList'
  import WorkflowIframe from '@/components/tools/WorkflowIframe'
  import { FormTypes } from '@/utils/JEditableTableUtil'
  import { JEditableTableMixin } from '@/mixins/JEditableTableMixin'
  import { BillModalMixin } from '../mixins/BillModalMixin'
  import { VALIDATE_NO_PASSED, getRefPromise, validateFormAndTables } from '@/utils/JEditableTableUtil'
  import { getMpListShort, handleIntroJs, randomNumber } from '@/utils/util'
  import JSelectMultiple from '@/components/jeecg/JSelectMultiple'
  import JUpload from '@/components/jeecg/JUpload'
  import JDate from '@/components/jeecg/JDate'
  import Vue from 'vue'
  import { getAction } from '@api/manage'
  import BillDetail from '@views/bill/dialog/BillDetail.vue'
  import SaleOrderPrint from '@views/bill/modules/SaleOrderPrint.vue'
  export default {
    name: "SaleOrderModal",
    mixins: [JEditableTableMixin, BillModalMixin],
    components: {
      BillDetail,
      ManyAccountModal,
      ImportItemModal,
      CustomerModal,
      AccountModal,
      HistoryBillList,
      WorkflowIframe,
      JUpload,
      JDate,
      JSelectMultiple,
      SaleOrderPrint,
      VNodes: {
        functional: true,
        render: (h, ctx) => ctx.props.vnodes,
      }
    },
    data () {
      return {
        isReadOnly: false,
        nowDate: this.dateToString(new Date()),
        record: {},
        cols: [],
        priceWarning: '',
        defaultTraffic: 'car',
        cities: [],
        dateFormat: 'YYYY-MM-DD',
        title:"操作",
        width: '1600px',
        moreStatus: false,
        // 新增时子表默认添加几行空数据
        addDefaultRowNum: 0,
        visible: false,
        operTimeStr: '',
        prefixNo: 'XSDD',
        fileList:[],
        model: {},
        labelCol: {
          xs: { span: 24 },
          sm: { span: 8 },
        },
        wrapperCol: {
          xs: { span: 24 },
          sm: { span: 16 },
        },
        refKeys: ['materialDataTable', ],
        activeKey: 'materialDataTable',
        materialTable: {
          loading: false,
          dataSource: [],
          columns: [
            { title: '仓库名称', key: 'depotId', width: '12%', type: FormTypes.select, placeholder: '请选择${title}', options: [],
              allowSearch:true, validateRules: [{ required: true, message: '${title}不能为空' }]
            },
            { title: '条码', key: 'barCode', width: '12%', type: FormTypes.popupJsh, kind: 'material', multi: true,
              validateRules: [{ required: true, message: '${title}不能为空' }]
            },
            { title: '名称', key: 'name', width: '10%', type: FormTypes.normal },
            { title: '规格', key: 'standard', width: '9%', type: FormTypes.normal },
            { title: '发货日期', key: 'sendDate', width: '9%', type: FormTypes.date },
            { title: '型号', key: 'model', width: '9%', type: FormTypes.normal },
            { title: '颜色', key: 'color', width: '5%', type: FormTypes.normal },
            { title: '扩展信息', key: 'materialOther', width: '5%', type: FormTypes.normal },
            { title: '库存', key: 'stock', width: '5%', type: FormTypes.normal },
            { title: '单位', key: 'unit', width: '4%', type: FormTypes.normal },
            { title: '多属性', key: 'sku', width: '4%', type: FormTypes.normal },
            { title: '数量', key: 'operNumber', width: '5%', type: FormTypes.inputNumber, statistics: true,
              validateRules: [{ required: true, message: '${title}不能为空' }]
            },
            { title: '单价', key: 'unitPrice', width: '10%', type: FormTypes.inputNumber},
            { title: '出厂单价', key: 'finalPrice', width: '10%', type: FormTypes.inputNumber},
            { title: '最低单价', key: 'lowDecimal', width: '10%', type: FormTypes.inputNumber},
            { title: '金额', key: 'allPrice', width: '10%', type: FormTypes.inputNumber, statistics: true },
            // { title: '税率', key: 'taxRate', width: '4%', type: FormTypes.inputNumber,placeholder: '%'},
            // { title: '税额', key: 'taxMoney', width: '5%', type: FormTypes.inputNumber, readonly: true, statistics: true },
            // { title: '合计', key: 'taxLastMoney', width: '7%', type: FormTypes.inputNumber, statistics: true },
            { title: '备注', key: 'remark', width: '6%', type: FormTypes.input }
          ]
        },
        confirmLoading: false,
        validatorRules:{
          operTime:{
            rules: [
              { required: true, message: '请输入单据日期!' }
            ]
          },
          sendDate:{
            rules: [
              { required: true, message: '请输入发货日期!' }
            ]
          },
          organId:{
            rules: [
              { required: true, message: '请选择客户!' }
            ]
          }
        },
        url: {
          add: '/depotHead/addDepotHeadAndDetail',
          edit: '/depotHead/updateDepotHeadAndDetail',
          detailList: '/depotItem/getDetailList'
        },
        cancelSplitting: false,
        splittingButton: '拆单',
        splitNumber: '',
        sendDate: null
      }
    },
    created () {
      getAction("/city/tree").then(res => {
        this.cities = res.data[0].children
      })
    },
    methods: {
      cityChange(val) {
        getAction("/city/getCost/"+val[2]+"/"+this.form.getFieldValue("traffic"), {}).then(res=>{
          this.$nextTick(() => {
            this.form.setFieldsValue(pick({cost: res.data}, "cost"))
          });
        })
      },
      trafficChange(val) {
        getAction("/city/getCost/"+this.supplier.city+"/"+val, {}).then(res=>{
          this.$nextTick(() => {
            this.form.setFieldsValue(pick({cost: res.data}, "cost"))
          });
        })
      },
      handleDateChange(mom, dateStr) {
        this.sendDate = mom
      },
      customHandleCancel() {
        this.materialTable.dataSource = []
        this.close();
      },
      dateToString(timeObj){
        let str = ''
        let year = timeObj.getFullYear();
        let month = timeObj.getMonth() + 1;
        let date = timeObj.getDate();
        str = year+"-"+month+"-"+date
        console.log(str)
        return str;
      },
      isSplitting() {
        if (this.$refs.materialDataTable.selectedRowIds.length === 1) {
          if (this.form.getFieldValue('splitNumber') === undefined || this.form.getFieldValue('splitNumber') === '') {
            this.$message.warning('请输入拆分单数')
          } else {
            let values = this.$refs.materialDataTable.getValuesSync({ rowIds: this.$refs.materialDataTable.selectedRowIds }).values
            let value = values[0];
            this.materialTable.dataSource = this.$refs.materialDataTable.getValuesSync({}).values
            if (this.materialTable.dataSource.length === 0) {
              this.materialTable.dataSource.push(value)
            }
            let avg_price = value.allPrice/parseInt(this.form.getFieldValue('splitNumber'))
            let avg_num = value.operNumber/parseInt(this.form.getFieldValue('splitNumber'))
            let avg_tax = parseInt(value.taxLastMoney)/parseInt(this.form.getFieldValue('splitNumber'))
            this.materialTable.dataSource = this.materialTable.dataSource.filter(item => {
              return item.id !== value.id
            })
            let send_date = new Date(this.form.getFieldValue('sendDate'))
            let days = this.form.getFieldValue('dayCycle') !== undefined && this.form.getFieldValue('dayCycle') !== null ? this.form.getFieldValue('dayCycle') : 7
            for (let i = 0; i < parseInt(this.form.getFieldValue('splitNumber')); i++) {
              let material = {
                id: new Date().getTime() + randomNumber(6),
                allPrice: avg_price,
                barCode: value.barCode,
                color: value.color,
                materialOther: value.materialOther,
                model: value.model,
                name: value.name,
                operNumber: avg_num,
                remark: value.remark,
                sendDate: this.dateToString(new Date(send_date.setDate(send_date.getDate() + days))),
                sku: value.sku,
                standard: value.standard,
                stock: value.stock,
                taxLastMoney: avg_tax,
                taxMoney: value.taxMoney,
                taxRate: value.taxRate,
                unit: value.unit,
                unitPrice: value.unitPrice
              }
              this.materialTable.dataSource.push(material)
            }
          }
        } else {
          this.$message.warning('请选择一条数据进行拆单')
        }
      },
      //调用完edit()方法之后会自动调用此方法
      editAfter() {
        this.billStatus = '0'
        this.currentSelectDepotId = ''
        this.changeColumnHide()
        if (this.action === 'add') {
          this.addInit(this.prefixNo)
          this.personList.value = ''
          this.fileList = []
          this.$nextTick(() => {
            handleIntroJs(this.prefixNo, 1)
          })
        } else {
          this.sendDate = this.model.sendDate
          this.model.operTime = this.model.operTimeStr
          if(this.model.accountId == null && this.model.accountIdList) {
            this.model.accountId = 0
            this.manyAccountBtnStatus = true
            this.accountIdList = this.model.accountIdList
            this.accountMoneyList = this.model.accountMoneyList
          } else {
            this.manyAccountBtnStatus = false
          }
          this.personList.value = this.model.salesMan
          this.fileList = this.model.fileName
          this.$nextTick(() => {
            this.form.setFieldsValue(pick(this.model,'organId', 'operTime', 'number', 'remark', "depotId",
              'discount','discountMoney','discountLastMoney','accountId','changeAmount','salesMan', 'sendDate', 'city', 'traffic', 'cost', 'transfer'))
          });
          // 加载子表数据
          let params = {
            headerId: this.model.id,
            mpList: getMpListShort(Vue.ls.get('materialPropertyList')),  //扩展属性
            linkType: 'basic'
          }

          let url = this.readOnly ? this.url.detailList : this.url.detailList;
          this.requestSubTableData(url, params, this.materialTable);
        }
        //复制新增单据-初始化单号和日期
        if(this.action === 'copyAdd') {
          this.model.id = ''
          this.model.tenantId = ''
          this.copyAddInit(this.prefixNo)
        }
        this.initSystemConfig()
        this.initCustomer()
        this.initSalesman()
        this.initAccount()
        this.initDepot()
      },
      //提交单据时整理成formData
      classifyIntoFormData(allValues, status) {
        let totalPrice = 0
        let billMain = Object.assign(this.model, allValues.formValue)
        let detailArr = allValues.tablesValue[0].values
        billMain.type = '其它'
        billMain.subType = '销售订单'
        billMain.defaultNumber = billMain.number
        detailArr = detailArr.filter(el => el.barCode !== '合计')
        for(let item of detailArr){
          // item.depotId = '' //订单不需要仓库
          totalPrice += item.allPrice-0
        }
        billMain.totalPrice = totalPrice
        if(billMain.accountId === 0) {
          billMain.accountId = ''
        }
        billMain.accountIdList = this.accountIdList.length>0 ? JSON.stringify(this.accountIdList) : ""
        billMain.accountMoneyList = this.accountMoneyList.length>0 ? JSON.stringify(this.accountMoneyList) : ""
        if(this.fileList && this.fileList.length > 0) {
          billMain.fileName = this.fileList
        } else {
          billMain.fileName = ''
        }
        if(this.model.id){
          billMain.id = this.model.id
        }
        billMain.salesMan = this.personList.value
        billMain.status = status
        return {
          info: JSON.stringify(billMain),
          rows: JSON.stringify(detailArr),
        }
      },
      handleHistoryBillList() {
        let organId = this.form.getFieldValue('organId')
        this.$refs.historyBillListModalForm.show('其它', '销售订单', '客户', organId);
        this.$refs.historyBillListModalForm.disableSubmit = false;
      },
      onAddedSale(event) {
        const { row, target } = event
        target.setValues([{ rowKey: row.id, values: { operNumber: 0 } }])
        target.setValues([{ rowKey: row.id, values: { sendDate: this.nowDate } }])
        if (this.currentSelectDepotId) {
          //如果单据选择过仓库，则直接从当前选择的仓库加载
          target.setValues([{ rowKey: row.id, values: { depotId: this.currentSelectDepotId } }])
        } else {
          getAction('/depot/findDepotByCurrentUser').then((res) => {
            if (res.code === 200) {
              let arr = res.data
              if (arr.length === 1) {
                target.setValues([{ rowKey: row.id, values: { depotId: arr[0].id + '' } }])
              } else {
                for (let i = 0; i < arr.length; i++) {
                  if (arr[i].isDefault) {
                    target.setValues([{ rowKey: row.id, values: { depotId: arr[i].id + '' } }])
                  }
                }
              }
            }
          })
        }
      },
      /** 确定按钮点击事件 */
      handleOkSale(type) {
        /** 触发表单验证 */
        this.getAllTable().then(tables => {
          /** 一次性验证主表和所有的次表 */
          return validateFormAndTables(this.form, tables)
        }).then(allValues => {
          if (typeof this.classifyIntoFormData !== 'function') {
            throw this.throwNotFunction('classifyIntoFormData')
          }
          if (allValues.formValue.splitNumber !== undefined) {
            allValues.formValue.splitting = '1'
          }
          this.cols = allValues.tablesValue[0].values
          this.record = allValues.formValue
          this.record.organName = this.findSupplier(this.record.organId).supplier
          this.record.cityEx = this.record.city
          for (let i = 0; i<this.cols.length; i++) {
            this.cols[i].depotName = this.findDepotName(this.cols[i].depotId)
          }
          for (let i=0; i<this.personList.options.length; i++) {
            if (this.personList.options[i].value === this.personList.value){
              this.record.salesManStr = this.personList.options[i].text
            }
          }
          if (allValues.formValue.city !== undefined && allValues.formValue.city !== null) {
            allValues.formValue.city = allValues.formValue.city.join(",")
            let details = allValues.tablesValue[0].values
            let priceWarning = false
            for (let i = 0; i < details.length; i++) {
              if (details[i].finalPrice < details[i].lowDecimal) {
                priceWarning = true
                break
              }
            }
            if (priceWarning) {
              let that = this
              this.$confirm({
                title: '请确认?',
                content: '出厂单价存在异常，需审核！',
                onOk() {
                  let formData = that.classifyIntoFormData(allValues, '0')
                  // 发起请求
                  return that.request(formData)
                },
                onCancel() {},
              });
            } else {
              let formData = this.classifyIntoFormData(allValues, '1')
              if (type === 1) {
                this.record.creatorName = JSON.parse(localStorage.pro__Login_Userinfo).value.username
                getAction('/city/getCityName/' + this.record.cityEx[1]).then(res => {
                  this.record.cityName = res.data
                  this.$refs.print.visible = true
                })
              }
              // 发起请求
              return this.request(formData)
            }
          }
        }).catch(e => {
          if (e.error === VALIDATE_NO_PASSED) {
            // 如果有未通过表单验证的子表，就自动跳转到它所在的tab
            this.activeKey = e.index == null ? this.activeKey : this.refKeys[e.index]
          } else {
            console.error(e)
          }
        })
      },
    }
  }
</script>
<style scoped>

</style>